

# Claims

[c1] What is claimed is:

1. A method for dynamically adjusting an operating speed of a microprocessor for the microprocessor to access at least a serial flash memory, wherein the serial flash memory is a program memory, and the digital data stored in the serial flash memory is programming data, the method comprising:

(a) reducing an executing speed of the microprocessor if the data that microprocessor required from the serial flash memory is not well prepared; and  
(b) executing the microprocessor at a normal speed if the data that microprocessor required from the serial flash memory is well prepared.

[c2] 2. The method of claim 1, wherein in step (a), reducing the executing speed of the microprocessor makes the executing speed of the microprocessor lower than the normal speed or totally suspends the microprocessor.

[c3] 3. The method of claim 1, wherein step (a) is capable of being achieved by adjusting an operating clock with an external circuit or with a circuit installed in the microprocessor, by inserting an NOP (No Operation) command

among commands, or by keeping a program counter unchanged.

- [c4] 4. The method of claim 1 involved with a buffering/controlling device, the method further comprising:
- (c) utilizing the buffering/controlling device to access a predetermined number of digital data stored in the serial flash memory;
  - (d) utilizing the microprocessor to access desired digital data from the buffering/controlling device;
  - (e) in step (b), utilizing the microprocessor to access the digital data located in the buffering/controlling device and continuing to operate the microprocessor at the normal speed when the desired digital data of the microprocessor are in the buffering/controlling device;
  - (f) in step (a), reducing the operating speed of the microprocessor when the desired digital data of the microprocessor are not in the buffering/controlling device; and
  - (g) after proceeding with step (f), transmitting the desired digital data of the microprocessor from the serial flash memory to the buffering/controlling device and to the microprocessor and recovering the operating speed of the microprocessor so that the microprocessor is capable of accessing the digital data.

- [c5] 5. The method of claim 4 further comprising:
- (h) in step (c), utilizing the buffering/controlling device to consecutively access the predetermined number of digital data at a starting address of the serial flash memory; and
  - (i) in step (d), (e), and (f), utilizing the microprocessor to emit an access address corresponding to the digital data to the buffering/controlling device, so that the buffering/controlling device is capable of judging whether the desired digital data of the microprocessor are located in the buffering/controlling device.
- [c6] 6. The method of claim 4, wherein a first data access rate is set between the buffering/controlling device and the microprocessor, and a second data access rate is set between the memory and the buffering/controlling device, wherein the first data access rate is higher than or equal to the second data access rate.
- [c7] 7. The method of claim 4, wherein the buffering/controlling device is a FIFO storage structure, a dynamic random access memory (DRAM), or a static random access memory (SRAM).
- [c8] 8. A method for dynamically adjusting an operating speed of a microprocessor for the microprocessor to access at least a serial flash memory and a random access

memory (RAM), wherein the serial flash memory and the random access memory are program memories, and the digital data stored in the serial flash memory or the random access memory is programming data, the method comprising:

(a) loading partial of the program codes from the serial flash memory to the random access memory before the microprocessor's requiring data; and

(b) reducing an executing speed of the microprocessor if the data that microprocessor required from the serial flash memory or the random access memory is not well prepared; and

(c) executing the microprocessor at a normal speed if the data that microprocessor required from the serial flash memory or the random access memory is well prepared.

- [c9] 9. The method of claim 8, wherein in step (b), reducing the executing speed of the microprocessor makes the executing speed of the microprocessor lower than the normal speed or totally suspends the microprocessor.
- [c10] 10. The method of claim 8, wherein step (b) is capable of being achieved by adjusting an operating clock with an external circuit or with a circuit installed in the microprocessor, by inserting an NOP (No Operation) command among commands, or by keeping a program counter unchanged.

- [c11] 11. The method of claim 8 involved with a buffering/controlling device, the method further comprising:
- (d) utilizing the buffering/controlling device to access a predetermined number of digital data stored in the serial flash memory or the random access memory;
  - (e) utilizing the microprocessor to access desired digital data from the buffering/controlling device;
  - (f) in step (c), utilizing the microprocessor to access the digital data located in the buffering/controlling device and continuing to operate the microprocessor at the normal speed when the desired digital data of the microprocessor are in the buffering/controlling device;
  - (g) in step (b), reducing the operating speed of the microprocessor when the desired digital data of the microprocessor are not in the buffering/controlling device;  
and
  - (h) after proceeding with step (g), transmitting the desired digital data of the microprocessor from the serial flash memory or the random access memory to the buffering/controlling device and to the microprocessor and recovering the operating speed of the microprocessor so that the microprocessor is capable of accessing the digital data.

- [c12] 12. The method of claim 11 further comprising:
- (i) in step (d), utilizing the buffering/controlling device to

consecutively access the predetermined number of digital data at a starting address of the serial flash memory or the random access memory; and

(j) in step (e), (f), and (g), utilizing the microprocessor to emit an access address corresponding to the digital data to the buffering/controlling device, so that the buffering/controlling device is capable of judging whether the desired digital data of the microprocessor are located in the buffering/controlling device.

- [c13] 13. The method of claim 11, wherein a first data access rate is set between the buffering/controlling device and the microprocessor, and a second data access rate is set between the serial flash memory and the buffering/controlling device, and a third data access rate is set between the random access memory and the buffering/controlling device, wherein the first data access rate is higher than or equal to the second data access rate, and the first data access rate is higher than or equal to the third data access rate.
- [c14] 14. The method of claim 11, wherein the buffering/controlling device is a FIFO storage structure, a dynamic random access memory (DRAM), or a static random access memory (SRAM).
- [c15] 15. The method of claim 8, wherein the random access

memory is a dynamic random access memory (DRAM).

- [c16] 16. A method for dynamically adjusting an operating speed of a microprocessor for the microprocessor to access at least a random access memory (RAM), wherein the random access memory are a program memory, and the digital data stored in the random access memory is programming data, the method comprising:
- (a) loading the digital data from a serial flash memory to the random access memory before the microprocessor's requiring data; and
  - (b) reducing an executing speed of the microprocessor if the data that microprocessor required from the random access memory is not well prepared; and
  - (c) executing the microprocessor at a normal speed if the data that microprocessor required from the random access memory is well prepared.
- [c17] 17. The method of claim 16, wherein in step (b), reducing the executing speed of the microprocessor makes the executing speed of the microprocessor lower than the normal speed or totally suspends the microprocessor.
- [c18] 18. The method of claim 16, wherein step (b) is capable of being achieved by adjusting an operating clock with an external circuit or with a circuit installed in the micro-

processor, by inserting an NOP (No Operation) command among commands, or by keeping a program counter unchanged.

- [c19] 19. The method of claim 16, involved with a buffering/controlling device, the method further comprising:
- (d) utilizing the buffering/controlling device to access a predetermined number of digital data stored in the random access memory;
  - (e) utilizing the microprocessor to access desired digital data from the buffering/controlling device;
  - (f) in step (c), utilizing the microprocessor to access the digital data located in the buffering/controlling device and continuing to operate the microprocessor at the normal speed when the desired digital data of the microprocessor are in the buffering/controlling device;
  - (g) in step (b), reducing the operating speed of the microprocessor when the desired digital data of the microprocessor are not in the buffering/controlling device;  
and
  - (h) after proceeding with step (g), transmitting the desired digital data of the microprocessor from the random access memory to the buffering/controlling device and to the microprocessor and recovering the operating speed of the microprocessor so that the microprocessor is capable of accessing the digital data.

- [c20] 20. The method of claim 19 further comprising:
- (i) in step (d), utilizing the buffering/controlling device to consecutively access the predetermined number of digital data at a starting address of the random access memory; and
  - (j) in step (e), (f), and (g), utilizing the microprocessor to emit an access address corresponding to the digital data to the buffering/controlling device, so that the buffering/controlling device is capable of judging whether the desired digital data of the microprocessor are located in the buffering/controlling device.
- [c21] 21. The method of claim 19, wherein a first data access rate is set between the buffering/controlling device and the microprocessor, and a second data access rate is set between the random access memory and the buffering/controlling device, wherein the first data access rate is higher than or equal to the second data access rate.
- [c22] 22. The method of claim 19, wherein the buffering/controlling device is a FIFO storage structure, a dynamic random access memory (DRAM), or a static random access memory (SRAM).
- [c23] 23. The method of claim 16, wherein the random access memory is a dynamic random access memory (DRAM).

- [c24] 24. A method for dynamically adjusting an operating speed of a microprocessor emulator for the microprocessor emulator to emulate the operation with a serial flash memory, the method comprising:
  - (a) reducing an executing speed of the microprocessor emulator for a certain period; and
  - (b) executing the microprocessor emulator at a normal speed after the certain period.
- [c25] 25 The method of claim 24, wherein in step (a) and (b), the certain period depends on the serial flash access time.
- [c26] 26. The method of claim 24, wherein in step (a), reducing the executing speed of the microprocessor emulator makes the executing speed of the microprocessor emulator lower than the normal speed or totally suspends the microprocessor emulator.
- [c27] 27. The method of claim 24, wherein step (a) is capable of being achieved by adjusting an operating clock with an external circuit or with a circuit installed in the microprocessor emulator, by inserting an NOP (No Operation) command among commands, or by keeping a program counter unchanged.
- [c28] 28. The method of claim 24, wherein the microprocessor

emulator is electrically connected to a microprocessor system that further comprises a buffering/controlling device, the method comprising:

- (c) utilizing the microprocessor emulator to emit an access address to the buffering/controlling device;
- (d) in step (b), operating the microprocessor emulator at the normal speed when the access address is in the buffering/controlling device; and
- (e) in step (a), reducing the operating speed of the microprocessor emulator when the access address is not in the buffering/controlling device.

[c29] 29. The method of claim 28 further comprising:

- (f) after proceeding with step (e), recovering the operating speed of the microprocessor emulator after a predetermined number of clock cycles.

[c30] 30. The method of claim 24, wherein the microprocessor emulator is electrically connected to a second memory, and the second memory is capable of being used to transmit at least an instruction to the microprocessor emulator.

[c31] 31. The method of claim 30, wherein the second memory is a static random access memory (SRAM), a flash memory, or a dynamic random access memory (DRAM).

- [c32] 32. The method of claim 28, wherein the buffering/controlling device is electrically connected to the serial flash memory, and the serial flash memory stores a plurality of digital data, the method further comprising:
- (g) utilizing the buffering/controlling device to access a predetermined number of digital data stored in the serial flash memory;
  - (h) in step (d), utilizing the buffering/controlling device to transmit the digital data corresponding to the access address to the microprocessor emulator when the access address is in the buffering/controlling device; and
  - (i) after proceeding with step (e), transmitting the digital data corresponding to the access address from the serial flash memory to the buffering/controlling device and to the microprocessor emulator and recovering the executing speed of the microprocessor emulator.
- [c33] 33. The method of claim 32, wherein in step (g), the buffering/controlling device consecutively accesses the predetermined number of digital data at a starting address of the serial flash memory.
- [c34] 34. The method of claim 32, wherein the serial flash memory is a program memory, and the digital data stored in the serial flash memory are programming codes.

- [c35] 35. The method of claim 32, wherein a first data access rate is set between the buffering/controlling device and the microprocessor emulator, and a second data access rate is set between the serial flash memory and the buffering/controlling device, wherein the first data access rate is higher than or equal to the second data access rate.
- [c36] 36. The method of claim 24, wherein the operating clock's frequency of the microprocessor emulator is capable of being adjusted by an external clock device.
- [c37] 37. The method of claim 28, wherein the buffering/controlling device is a FIFO storage structure, a dynamic random access memory (DRAM), or a static random access memory (SRAM).
- [c38] 38. The method of claim 24, wherein the microprocessor emulator is an in-circuit emulator.